<template>
	<div>
		<navigation-bar>
			<div class="searchContent">
				<el-input v-model="drugName" placeholder="请输入药品名称" size="mini"
					style="width: 150px; margin-right: 10px"></el-input>
				<custom-button type="search" style="margin-right: 10px" @searchClick="searchClick"></custom-button>
				<custom-button type="reset" style="margin-right: 10px" @resetClick="resetClick"></custom-button>
				<custom-button type="add" @addClick="addClick"></custom-button>
			</div>
		</navigation-bar>
		<table-index :dataSource="dataSource" :tableColumns="tableColumns" :btnList="btnList" :pageSize="pageSize"
			:pageCount="pageCount" :pageNo="pageNo" @pageChange="pageChange" @editRow="editRow" @viewRow="viewRow"
			@deleteRow="deleteRow"></table-index>

		<div v-if="dialogShow">
			<custom-dialog :title="dialogTitle" size="large" @dialogClose="dialogClose">
				<form-index :formConfig="formConfig" @submit="submit" :type="type">
					<!--  <div>这里还可以插入其它内容进行拓展</div> -->
				</form-index>
			</custom-dialog>
		</div>
	</div>
</template>

<script>
import { TestDrugFormConfig } from "@/assets/form/managementCenter/projectManage/testDrugForm"
import customDialog from "@/components/customComponents/customDialog"
import customButton from "@/components/customComponents/customForm/customButton"
import formIndex from "@/components/customComponents/customForm/formIndex"
import tableIndex from "@/components/customComponents/customeTable/tableIndex"
import navigationBar from "@/components/customComponents/managementCenter/navigationBar"
import { AjaxCommon } from "@/libs/apiCommon"
import { PopupCommon } from "@/libs/popupCommon"
import { SessionCommon } from "@/libs/sessionCommon"
export default {
	components: {
		navigationBar,
		customButton,
		tableIndex,
		customDialog,
		formIndex,
	},
	data() {
		return {
			drugName: "",
			drugType: "",
			// table 相关参数  begin
			dataSource: [],
			tableColumns: [
				{
					prop: "drugType",
					label: "药品类型",
					dictName: "drug_type",
				},
				{
					prop: "drugName",
					label: "药品名称",
				},
				{
					prop: "drugNorms",
					label: "规格",
				},
				{
					prop: "drugUnit",
					label: "单位",
				},
				{
					prop: "drugWay",
					label: "给药途径",
					dictName: "drug_way",
				},
				{
					prop: "drugCondition",
					label: "给药条件",
				},
			],
			btnList: ["edit", "view", "delete"],
			pageSize: 20,
			pageCount: 100,
			pageNo: 1,
			// table 相关参数  end

			// 弹窗是否显示
			dialogShow: false,
			// 弹窗标题 (新增修改不同)
			dialogTitle: "",

			// form的配置信息
			formConfig: TestDrugFormConfig,
			type: "add",
		}
	},

	methods: {
		submit(d) {
			let self = this
			if (d.id) {
				AjaxCommon("/ccdc/cfg/pm/pmExpUseDrug/edit", "post", d)
					.then((res) => {
						if (res.data.code == 200) {
							PopupCommon.notify("success", "操作成功")
							self.initPage()
							self.dialogClose()
						} else {
							PopupCommon.notify("error", res.data.message)
						}
					})
					.catch((err) => {
						PopupCommon.notify("error", err.message)
					})
			} else {
				delete d.id
				AjaxCommon("/ccdc/cfg/pm/pmExpUseDrug/add", "post", d)
					.then((res) => {
						if (res.data.code == 200) {
							PopupCommon.notify("success", "操作成功")
							self.initPage()
							self.dialogClose()
						} else {
							PopupCommon.notify("error", res.data.message)
						}
					})
					.catch((err) => {
						PopupCommon.notify("error", err.message)
					})
			}
		},
		dialogClose() {
			this.dialogShow = false
		},
		searchClick() {
			this.pageNo = 1
			this.initPage()
		},
		resetClick() {
			this.drugName = ""
			this.drugType = ""
		},
		addClick() {
			let formConfigItem = this.formConfig
			formConfigItem.map((t) => {
				Object.keys(t).map((res) => {
					if (res == "fieldName") {
						t.filedValue = ""
					}
				})
			})
			this.formConfig = formConfigItem
			this.type = "add"
			this.dialogShow = true
			this.dialogTitle =
				"新增" + JSON.parse(SessionCommon.getCurrentMenuInfo()).title
		},
		// 分页点击事件
		pageChange(p) {
			this.pageNo = p
			this.initPage()
		},
		editRow(d) {
			this.type = "edit"
			let formConfigItem = this.formConfig
			formConfigItem.map((t) => {
				Object.keys(t).map((res) => {
					if (res == "fieldName") {
						t.filedValue = d.data[t[res]]
					}
				})
			})
			this.formConfig = formConfigItem
			this.dialogShow = true
			this.dialogTitle =
				"编辑" + JSON.parse(SessionCommon.getCurrentMenuInfo()).title
		},
		viewRow(d) {
			this.type = "look"
			let formConfigItem = this.formConfig
			formConfigItem.map((t) => {
				Object.keys(t).map((res) => {
					if (res == "fieldName") {
						t.filedValue = d.data[t[res]]
					}
				})
			})
			this.formConfig = formConfigItem
			this.dialogShow = true
			this.dialogTitle =
				"查看" + JSON.parse(SessionCommon.getCurrentMenuInfo()).title
		},
		deleteRow(d) {
			const id = d.data.id
			let self = this
			AjaxCommon("/ccdc/cfg/pm/pmExpUseDrug/delete?id=" + id, "delete", { optReason: d.optReason }).then(
				(res) => {
					console.log(res, "res...............")
					if (res.data.code == 200) {
						PopupCommon.notify("success", "删除成功")
						self.initPage()
						self.dialogClose()
					} else {
						PopupCommon.notify("error", res.data.message)
					}
				}
			)
		},
		// 初始化事件
		initPage() {
			let self = this
			AjaxCommon("/ccdc/cfg/pm/pmExpUseDrug/listByPage", "post", {
				drugName: this.drugName,
				drugType: this.drugType,
				pageNo: this.pageNo,
				pageSize: this.pageSize,
			}).then((res) => {
				if (res.data.code == 200) {
					self.dataSource = res.data.result.records
					self.pageCount = res.data.result.total
				} else {
					PopupCommon.notify("error", res.data.message)
				}
			})
		},
	},
	mounted() {
		this.initPage()
	},
}
</script>

<style></style>
